package com.atguigu.linklist;

import java.util.HashMap;
import java.util.Map;

public class RandList {
    public static ListNode copyRandomList(ListNode head){
        Map<ListNode,ListNode> map=new HashMap<>();
        if(head==null) return null;
        ListNode cur=head;
        //拷贝
        while(cur!=null){
            ListNode node=new ListNode(cur.val);
            map.put(cur,node);
            cur=cur.next;
        }
        //遍历map的value来串成一条新链表
        cur=head;
        while(cur!=null){
            ListNode tmp=map.get(cur);   //获得value，即新节点
            tmp.next=map.get(cur.next);
            tmp.random=map.get(cur);
            cur=cur.next;
        }
        //拷贝完成
        return map.get(head);
    }
}
